Hsc adds some special attributes, which can be quite useful to include special data or configure the parser.
Hsc.Anchor
- destination URI of last anchor
Hsc.Click-Here
- keywords for "click here"-syndrome
Hsc.Color-Names
- values to be used as colors-names
Hsc.Content
- content text of current container macro
Hsc.Document.Name
- filename of html-object
Hsc.Document.Path
- directory part of html-object
Hsc.Document.URI
- full relative URI of html-object
Hsc.Exec.Result
- return-code of command invoked by <$exec>
Hsc.LF
- a single linefeed-character
Hsc.Source.Name
- filename of hsc-source
Hsc.Source.Path
- directory part of hsc-source
Hsc.Source.File
- full path and filename of hsc-source
Hsc.System
- value depending on operating system
Hsc.Format.Filesize
- how to render GetFileSize()
Hsc.Format.Time
- how to render GetTime()
and GetGMTime()
Hsc.TMP.*
- temporary attributes for internal use
This attribute is defined internally during startup and is maintained by hsc. It contains the URI of the last anchor referenced to.
Example:For updates, take a look at the <A HREF="http://www.giga.or.at/~agi/hsc/">hsc-support-page</A> at <STRONG><(HSC.ANCHOR)></STRONG>.will be converted to:
For updates, take a look at the hsc-support-page at http://www.giga.or.at/~agi/hsc/.
This attribute is defined internally during startup and is
maintained by hsc. It contains the the text which will be inserted
if a <$content>
shows up, and is updated at every call to a
container macro.
These attributes are defined internally during startup and are read-only. They contain the filename, the directory and the whole relative URI of the to be created html-object.
For example,hsc FROM people/hugo.hsc TO html:my_project/will lead to
attribute | value |
---|---|
Hsc.Document.Name | "hugo.html" |
Hsc.Document.Path | "people/" |
Hsc.Document.URI | "people/hugo.html" |
Hsc.Document.Path
does not contain the whole
destination directory, but only the relative path.
<$exec>
. It is updated after every call of this hsc-tag.
\n
'') and can be used to include linefeeds into
attribute-values without hsc whining about them.
These attributes are defined internally during startup and are read-only. They contain the filename, the directory and the full path and filename of the hsc-source you have specified when invoking hsc.
For example,hsc FROM people/hugo.hsc TO html:my_project/will lead to
attribute | value |
---|---|
Hsc.Source.Name | "hugo.hsc" |
Hsc.Source.Path | "people/" |
Hsc.Source.File | "people/hugo.hsc" |
This attribute is defined internally during startup and is read-only. It contains a value depending on the operating system hsc is running on.
OS | Hsc.System |
---|---|
AmigaOS | AMIGA |
RiscOS | RISCOS |
BeOS | BEOS |
NextStep | NEXTSTEP |
Unixoid | UNIX |
<$exec>
for an example how to include a
listing of the current directory, working with more then only
a specific OS.
For several tasks, hsc declares it's own temporary attributes for internal use. Most of them you can not use inside your own expressions. The only reason why I list them here is, that some of them might show up in messages.
For example, if you are using the special tag <(...)> (insert expression),
hsc creates an attribute Hsc.TMP.insert.expression
to
assign the value of the expression you passed between the brackets. If
this expression contains errors, you will achieve a message mentioning
the attribute Hsc.TMP.insert.expression
.
This attribute is defined in hsc.prefs and can be altered to the user's needs. However, it's value is scanned only once (immediately after processing hsc.prefs and later changes will not be recognised by hsc.
For attributes of type
COLOR
,
you can not only use the
cryptic #rrggbb
-style, but also use some predefined
values. With this attribute you can declare which values hsc should
know about, each separated by a vertical bar (``|
'').
This one contains all values recommended for html-0.32 and is in the hsc.prefs that came with this distribution.
This attribute is defined in hsc.prefs and can be altered to the user's needs. However, it's value is only scanned once and later changes will not be recognised by hsc.
Inside an anchor tag (<A HREF="...">
), the normal text is
scanned for special keywords indicating a ``click here''-syndrome.
With this attribute you can declare these keywords,
each separated by a vertical bar (``|
'').
Example:
<$define Hsc.Click-Here:string/c="click|here">
When processing German documents, probably this one would fit better:
<$define Hsc.Click-Here:string/c="klicken|hier">
GetFileSize()
should be rendered. Conversion specifications:
%b is replaced by the filesize in bytes. %k is replaced by the filesize in kilo-bytes. %m is replaced by the filesize in mega-bytes. %g is replaced by the filesize in giga-bytes. %a is replaced by the filesize, with a reasonable unit computed automatically %u is replaced by the unit for %aThis attribute is defined internally during startup, and contains the value
"%a%u"
, leading to results like "123K"
or
"12M"
. It can be changed by the user at any time.
GetTime()
and GetGMTime()
should be rendered.
Conversion specifications
(Techn. Note: These are the same as for ANSI-C's strftime()
):
%A is replaced by the full weekday name. %a is replaced by the abbreviated weekday name, where the abbreviation is the first three characters. %B is replaced by the full month name. %b or %h is replaced by the abbreviated month name, where the abbreviation is the first three characters. %C is equivalent to ``%a %b %e %H:%M:%S %Y'' %c is equivalent to ``%m/%d/%y''. %D is replaced by the date in the format ``mm/dd/yy''. %d is replaced by the day of the month as a decimal number (0131). %e is replaced by the day of month as a decimal number (131); single digits are preceded by a blank. %H is replaced by the hour (24hour clock) as a decimal number (0023). %I is replaced by the hour (12hour clock) as a decimal number (0112). %j is replaced by the day of the year as a decimal number (001366). %k is replaced by the hour (24hour clock) as a decimal number (023); single digits are preceded by a blank. %l is replaced by the hour (12hour clock) as a decimal number (112); single digits are preceded by a blank. %M is replaced by the minute as a decimal number (0059). %m is replaced by the month as a decimal number (0112). %n is replaced by a newline. %p is replaced by either ``AM'' or ``PM'' as appropriate. %R is equivalent to ``%H:%M'' %r is equivalent to ``%I:%M:%S %p''. %t is replaced by a tab. %S is replaced by the second as a decimal number (0060). %s is replaced by the number of seconds since the Epoch, UCT. %T or %X is equivalent to ``%H:%M:%S''. %U is replaced by the week number of the year (Sunday as the first day of the week) as a decimal number (0053). %W is replaced by the week number of the year (Monday as the first day of the week) as a decimal number (0053). %w is replaced by the weekday (Sunday as the first day of the week) as a decimal number (06). %x is equivalent to ``%m/%d/%y %H:%M:%S''. %Y is replaced by the year with century as a decimal number. %y is replaced by the year without century as a decimal number (0099). %Z is replaced by the time zone name. %% is replaced by ``%''.This attribute is defined internally during startup, and contains the value ``
%d-%b-%Y, %H:%M
'', leading to results like
"10-Nov-1997, 02:26
".